STRUCTURES

Section: Miscellaneous Library Functions (3X)
Updated: August 6, 1990
Index Return to Main Contents
 

NAME

structures - aggregated data definitions  

SYNOPSIS

#include structures.f83

structures  

DESCRIPTION

Allows composition of data field description to build structures. A basic language extension library in the tile forth kernel and used throughout the source code library to describe data structures. The "structures" package extends the traditional "record" or "structure" concept and allows initialization and high level management code to be defined together with the structure itself.
: align ( -- )
Used within a structure type field definition section to align the current field address to an even address.
: as ( -- struct.type) immediate
Used in the following form:
as <struct-type-name> ( -- struct.type)
Returns the address of the body of the structure type information. This address may be passed to the structure instance initialization function, "initiate".
: assign ( x y -- ) immediate
Used in the following form:
x y assign <struct-type-name>
or
x y assign <prim-type-name>
Assigns the structure or primitive pointed to by "y" the value of "x". The primitive types are equivalent to the structure type field names, "byte", "word", "long", "ptr" and "enum".
struct.field byte ( -- )
Used in the following form:
byte <field-name> ( addr1 -- addr2)
within a structure type definition section to create an access field name to a byte.
: bytes ( n -- )
Used in the following form:
<number> bytes <field-name> ( addr1 -- addr2)
within a structure type definition section to create a field access name to a given <number> of bytes.
struct.field enum ( -- )
Used in the following form:
enum <field-name> ( addr1 -- addr2)
within a structure type definition section to create a field access name to an enumerate. The size of an enumerate field is four bytes.
: initiate ( addr struct.type -- )
Used in the following form:
<instance> as <struct-type-name> initiate
Take a pointer to a memory area and initializes it according to the initialization code for the structure type given as the second parameter. Parameters to this code section can be passed as usual on the parameter stack.
struct.field long ( -- )
Used in the following form:
long <field-name> ( addr1 -- addr2)
within a structure type definition section to create a field access name to a long number. The size of a long is four bytes.
: new-struct ( -- addr) immediate
Used in the following form:
new-struct <struct-type-name> ( -- addr)
to allocate and initialize an instance of a structure type. A pointer to the instance is returned. The instance is not bound to any variable.
: not-equal ( x y -- bool) immediate
Used in the following form:
x y not-equal <struct-type-name>
or
x y not-equal <prim-type-name>
to compare two structure instances. The primitive types are equivalent to the structure type field names, "byte", "word", "long", "ptr" and "enum".
struct.field ptr ( -- )
Used in the following form:
ptr <field-name> ( addr1 -- addr2)
within a structure type definition section to create a field access name to a pointer. The size of a pointer is four bytes.
: sizeof ( -- num) immediate
Used in the following forms:
sizeof <struct-type-name>
or     

sizeof <prim-type-name>
Returns the size, in bytes, of a structure or primitive type. The primitive types are "byte", "word", "long", "ptr" and "enum".
: struct ( -- )
Used in the following form:
struct <struct-type-name> <field-name> ( addr1 -- addr2)
within a structure type definition section to create a field access name to a structure. The structure is not initialized automatically by the structure type. This should be performed by the initialization code of the structure type it is a part of. This may be performed with the words "as" and "initiate". Remember to pass necessary parameters to the initialization code.
: struct.does ( addr -- ) immediate compilation
Used within a structure type definition section to define the end of the structure layout or initialization code and the beginning of the instance action code. At run-time, performed for entry bounded (named) instance, the code receives a pointer to the instance as parameter.
: struct.end ( -- ) immediate
Used to terminate a structure type definition.
: struct.init ( addr -- )
Used within a structure type definition section to terminate the structure layout and the beginning the definition of the initialization
 code section. At run-time the code receives a pointer to the instance as a parameter.
: struct.type ( -- )
Used in the following forms:
struct.type <struct-type-name> ( ... -- )
<struct-type-layout>
struct.init ( ... addr -- ...)
<initialization-part>
struct.does ( ... addr -- ...)
<instance-part>
struct.end
and then:
<struct-type-name> <instance-name>
Starts the definition of a structure type. The layout section <struct-type-layout> may contain the words; <n> bytes <field-name>, allocates "n" bytes, byte <field-name>, a byte, word <field-name>, a word, long <field-name>, a long, ptr <field-name>, a pointer, enum <field-name>, an enumerative, and struct <struct-type-name> <field-name>, a structure. To align a field to even address use "align". The initialization code receives a pointer to the block to initialize and any additional parameters. Thus additional memory may be allocated directly after the block. If the structure contains structure fields these should be initialized by the initialization code. For this "as" and "initiate" are used; <instance> as <struct-type-name> initiate. The normal action performed by a instance of a structure type is to return the address to the instance. The optional "struct.does" part redefines the normal action of a created structure block. It receives a pointer to the instance as parameter and any additional parameters. The sections "struct.init" and "struct.does" are optional.
vocabulary structures ( -- )
Vocabulary for structure type extensions. Include into the vocabulary search structure, "context", to allow use of structures and description of aggregated data structures.
: this ( -- addr)
Returns the compilation address of the latest defined word.
struct.field word ( -- )
Used in the following form:
word <field-name> ( addr1 -- addr2)
within a structure type definition to create a field access name to a word. The size of a word is two bytes.
 

INTERNALS

Private definitions in the structures vocabulary;
field +size ( struct.type -- addr) private
Field for accessing the size of a structure type. This field is a long containing the number of bytes to allocate for an instance of the structure type.
field +initiate ( struct.type -- addr) private
Field for accessing the initialization code of a structure type. This field is a "ptr" containing a pointer to the initialization code for the structure type. A zero value, "nil", indicates that the structure type does not perform initialization.
: struct.field ( bytes -- ) private
Used in the following form:
<bytes> struct.field <field-type-name>
to create additional field types other than "byte" etc.
: make-struct ( struct.type -- addr) private
Given a pointer to a structure type information block, as generated by "as", allocates memory in the dictionary and initializes it. Returns a pointer to the created instance.
 

SEE ALSO

tile(1), forth(3X).  

EXAMPLES

An example showing how to defined a list structure:

struct.type LIST ( -- )
        ptr +next ( list -- addr)
struct.init ( list -- )
        nil swap +next !
struct.end

sizeof LIST . 
new-struct LIST constant x

LIST y

 

NOTE

The function list is sorted in ASCII order. The type and mode of
the entries are indicated together with their parameter stack effect.

The "structures" library optimizes the first field so that access becomes an immediate word with no effect. The most common accessed field should be placed first in a "structure" definition.  

COPYING

Copyright (C) 1990 Mikael R.K. Patel

Permission is granted to make and distribute verbatim copies of this manual provided the copyright notice and this permission notice are preserved on all copies.

Permission is granted to copy and distribute modified versions of this manual under the conditions for verbatim copying, provided also that the section entitled "GNU General Public License" is included exactly as in the original, and provided that the entire resulting derived work is distributed under the terms of a permission notice identical to this one.

Permission is granted to copy and distribute translations of this manual into another language, under the above conditions for modified versions, except that the section entitled "GNU General Public License" may be included in a translation approved by the author instead of in the original English.  

AUTHOR

Mikael R.K. Patel
Computer Aided Design Laboratory (CADLAB)
Department of Computer and Information Science
Linkoping University
S-581 83 LINKOPING
SWEDEN
Email: mip@ida.liu.se

 

Index

NAME
SYNOPSIS
DESCRIPTION
INTERNALS
SEE ALSO
EXAMPLES
NOTE
COPYING
AUTHOR

This document was created by man2html, using the manual pages.
Time: 08:59:41 GMT, January 07, 2023